<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <!-- 引入Vue -->
    <script src="../js/vue.js"></script>
    <style>
        *{
            margin-top: 20px;
        }

        .demo1{
            height: 50px;
            background-color: aqua;
        }
        .box1{
            padding: 5px;
            background-color: aqua;
        }
        .box2{
            background-color: orange;
        }
    </style>
    <title>事件修饰符</title>
    
</head>
<body>
    
    <!-- 
       Vue中的事件修饰符：
            1.prevent：阻止默认事件（常用）;
            2.stop：阻止事件冒泡（常用）;
            3.once：事件只触发一次（常用）;
            4.capture：使用事件的捕获模式;
            5.self：只有 event.target 是当前操作的元素时才触发事件;
            6.passive：事件的默认行为立即执行，无需等待事件回调执行完毕;

        注意：一个事件可以使用多个修饰符。例如：既阻止默认事件又阻止事件冒泡 @click.prevent.stop="xxxx"
     -->


    <!-- 容器 -->
    <div id="root">
        <h2>欢迎来到{{name}}战场</h2>
        <!-- 阻止默认事件（常用） -->
        <a href="http://www.baidu.com" @click.prevent="showInfo($event)">点我提示信息</a>

        <!-- 阻止事件冒泡（常用） -->
        <div class="demo1" @click="showInfo($event)">
            <!-- <button @click.stop="showInfo($event)">点我提示信息(冒泡)</button> -->
            <!-- 修饰符可以连续写 -->
            <a href="http://www.baidu.com"  @click.prevent.stop="showInfo($event)">点我提示信息(冒泡)</a>
        </div>
            
        <!-- 事件只触发一次（常用） -->
        <button @click.once="showInfo($event)">点我提示信息（事件只触发一次）</button>

        <!-- 使用事件的捕获模式 -->
        <div class="box1" @click.capture="msg1($event,1)">
            div1
            <div class="box2" @click="msg1($event,2)"> div2 </div>
        </div>

        <!-- 只有 event.target 是当前操作的元素时才触发事件 -->
        <div  class="demo1" @click.self="msg1($event,'外')">
            <button @click="msg1($event,'内')">点我提示信息</button>
        </div>

        <!--  -->

    </div>

    <script type="text/javascript">
        Vue.config.productionTip=false; // 阻止 vue 在启动时生成生产提示。

       const vm = new Vue({
           el:'#root',
           data:{
               name:'北凉',
             
           },
           methods:{
               showInfo(){
                   alert('hello')
               },
               msg1(event,msg){
                   console.log(msg);
               } 

           }

        })
        console.log("@@",vm);
    </script>
</body>
</html>